草庐IT

c++ - Visual Studio 和 Boost::Test

全部标签

c++ - 使用 fprintf 获取访问冲突写入位置 0x00000014

我在VisualStudio2010上工作。该程序本身最初是为CUDA的future端口设计的,所以一切都准备好了,但现在我只是测试它是否适用于纯C++(实际上我现在正尝试坚持使用c,因为我对它更熟悉)。相关代码为:#defineNMBR_EXP_ENERGIES21#defineNMBR_Ls3#defineNMBR_POINTS20000intNMBR_EXP_ENERGIES_L[NMBR_Ls];voidwrite_results(double**u,int*NmbrNodes,int*div){constcharprefix[]="wave_function_";charfi

c++ - boost::condition 会 boost 性能吗?

我们有一个多线程应用程序。在当前的实现中,thread1在启动时创建并定期(大约每秒,可配置)唤醒以检查磁盘是否有可能保存的文件。这些文件由另一个线程保存,thread2。正在运行的thread1及其定期唤醒可能会降低应用程序的速度。现在我们有机会使用boost::condition变量将thread1阻塞,直到thread2通知它。通过这样做,需要创建一个标志以避免来自thread2的不必要通知,并且该标志需要同步并由thread2以高频率(几秒钟内数百次)检查>。或者每次写入时都会通知thread1。我的问题如下:在boost::condition实现中,thread1仍然需要频繁

c++ - boost::thread 应该在无限循环中运行并等待没有互斥量的新输入

我有三个线程,我想一直运行到无限循环。线程对具有状态的对象进行操作,每个线程根据对象的状态执行或休眠。我希望输入线程继续检查state=1的任何新对象并继续处理它,或者等待它。classmyclass{intstate;myclass(){this->state=0;}voidsetState(intx){//setthis->statetox}intgetState(){//returnthis->state}//stuff}voidfoo1(myclass*ob){//stuffwhile(ob->getState()!=0||ob->getState()!=1){//sleepf

c++ - 读取控制台调色板的 RGB 值

肉类在C或C++中有什么方法可以直接读取调色板的RGB值吗?特别有趣的是xterm(和其他)使用的扩展颜色空间来定义多达256种终端颜色。土bean典型的例子是我想定义自己的颜色(使用ANSI转义序列,例如\e]4;3;rgb:cc/78/33\e\\,或者直接在c)中,但我需要在重新定义用户颜色之前保存它们(万一他们已经重新定义了颜色),以便我可以在程序完成时恢复它们。破坏用户设置并不好。现在我的目标是使用ANSI转义序列以客户端方式执行此操作。但由于我找不到如何获得颜色,所以我开始考虑用C或C++代替。该解决方案将编写为具有native扩展(基本上是嵌入式c或c++代码)的ruby

c++ - 如何让 boost::object_pool 线程安全?

在询问Isthereafasterheapallocation/deallocationmechanismavailablethanboost::object_pool?后,我得到反馈说这个对象池不是线程安全的。所以我写了一个ObjectFactory包装boost::object_pool并添加互斥锁:#includeusingstd::shared_ptr;#include#includetemplateclassObjectFactory{private:structSharedDeleter{ObjectFactory*m_pFact;SharedDeleter(ObjectF

c++ - 解决循环依赖难题 "elegantly"

所以我正在开发一种编程语言,它可以编译为字节码以供VM执行,也可以编译为C作为中间语言以编译为native二进制文件。我选择C​​是因为它足够低级且可移植,通过重用现有编译器而不必编写编译器来为每个不同的平台及其异常情况进行汇编,从而节省了大量工作。但是现有的编译器有其缺点,其中之一就是循环依赖问题。我想以一种优雅的方式(与C/C++不同)解决循环依赖,而无需笨拙的前向声明,不必使用指针和额外的间接寻址和浪费的内存,不必将声明与定义分开等等......换句话说,像某些编程语言一样,将此问题从开发人员手中拿走。在我看来,当前C/C++编译器的主要问题是它们无法“展望future”,即使它

c++ - boost spirit 适合这种情况吗?

我有这样一种情况,我试图从名称-值对流中构建一个HDF复合类型(为简单起见,我们假设一个值可以是double型或字符型字符串)。需要明确的是,数字数据已经是二进制的——它不是字符串。名称提供结构信息(这是数组的一部分吗?这是嵌套复合类型的一部分吗?)。我想制作一个标记vector,使用名称信息插入标记(例如,“[”和“]”分隔数组,“{”和“}”分隔嵌套化合物),否则使用值(value)。从文档中我不清楚Spirit二进制解析器是否是处理数值的合适选择。 最佳答案 我无法判断“其余”(即非二进制数据)是否有理由使用PEG解析器生成器

c++ - 确定哪个信号导致了 EINTR?

我正在运行一个epoll循环,有时我对epoll_wait的调用返回-1,errno设置为EINTR。有时,我希望这样可以结束epoll循环,例如SIGTERM或SIGINT。但是我用-pg标志编译了这段代码,因此会发出周期性的SIGPROF(27)信号来停止我的循环。那么...是否可以打开signum以便我可以确定何时退出或继续?我想避免使用全局变量来跟踪最近发射的信号。 最佳答案 在SIGTERM和SIGINT上添加信号处理程序。在这些处理程序中,您设置了一个变量,您可以在主epoll循环中检查该变量

c++ - 使用 boost 的 Glob 风格正则表达式模式匹配

我需要搜索与某些模式匹配的文件,该模式类似于使用boost在glob命令行中给出的模式。例如:如果输入是myFiles*.c,它应该匹配文件myFiles.c、myFiles1.c、myFiles123.c等。尝试在perl模式下使用boost::regex_match。但我必须将输入模式作为myfiles.*.c而不是myFiles*.c。我可以识别myfiles*.c并将其转换为myFiles.*.c并在perl模式下将其提供给boost::regex_match。但是输入模式可以是glob样式中的任何有效正则表达式,因为它是为命令行实用程序提供的。在boost中有什么方法可以以g

c++ - 使用 boost::asio ssl 服务器减少每次连接的内存使用

我正在使用boost::asio开发ssl服务器。我希望尽可能减少每个ssl连接的内存使用量。我的代码主要来源于boost::asio::sslexample服务器示例。这意味着我将session存储为Session类对象,它具有sslContext属性、已注册的read_handler等(与示例中的情况差不多)我能找到的所有优化都是启用SSL_MODE_RELEASE_BUFFERS和SSL_OP_NO_COMPRESSION。现在我每个连接大约55kB。但是根据thisthread,您可以将内存使用量减少到11kB。还有什么我可以做的来减少这种使用吗?操作系统:Ubuntu11.0